package com.huike.report.mapper;

import java.util.List;
import java.util.Map;

import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

/**
 * 首页统计分析的Mapper
 */
@Mapper
public interface ReportMapper {

    /**=========================================基本数据========================================*/
    /**
     * 获取线索数量
     *
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @param username        用户名
     * @return
     */
    Integer getCluesNum(@Param("startTime") String beginCreateTime,
                        @Param("endTime") String endCreateTime,
                        @Param("username") String username);

    /**
     * 获取商机数量
     *
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @param username        用户名
     * @return
     */
    Integer getBusinessNum(@Param("startTime") String beginCreateTime,
                           @Param("endTime") String endCreateTime,
                           @Param("username") String username);

    /**
     * 获取合同数量
     *
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @param username        用户名
     * @return
     */
    Integer getContractNum(@Param("startTime") String beginCreateTime,
                           @Param("endTime") String endCreateTime,
                           @Param("username") String username);

    /**
     * 获取合同金额
     *
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @param username        用户名
     * @return
     */
    Double getSalesAmount(@Param("startTime") String beginCreateTime,
                          @Param("endTime") String endCreateTime,
                          @Param("username") String username);



    /**=========================================今日简报========================================*/

    /**
     * 查询今日线索数目
     */
    Integer getTodayCluesNum(@Param("username") String username);

    /**
     * 查询今日商机数目
     * @param username 用户名
     */
    Integer getTodayBusinessNum(String username);



    /**
     * 查询今日合同数目
     * @param username 用户名
     */
    Integer getTodayContractNum(String username);



    /**
     * 查询今日销售金额
     * @param username 用户名
     */
    Double getTodaySalesAmount(String username);


    /**=========================================今日简报========================================*/


    /**=========================================待办事项========================================*/

    /**
     * 查询待跟进线索数目
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @param username        用户名
     */
    Integer getTofollowedCluesNum(@Param("beginTime") String beginCreateTime,
                                  @Param("endTime") String endCreateTime,
                                  @Param("username") String username);

    /**
     * 查询待跟进商机数目
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @param username        用户名
     */
    Integer getTofollowedBusinessNum(@Param("beginTime") String beginCreateTime,
                                     @Param("endTime") String endCreateTime,
                                     @Param("username") String username);

    /**
     * 查询待分配线索数目
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @param username        用户名
     */
    Integer getToallocatedCluesNum(@Param("beginTime") String beginCreateTime,
                                   @Param("endTime") String endCreateTime,
                                   @Param("username") String username);

    /**
     * 查询待分配商机数目
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @param username        用户名
     */
    Integer getToallocatedBusinessNum(@Param("beginTime") String beginCreateTime,
                                      @Param("endTime") String endCreateTime,
                                      @Param("username") String username);

    /**=========================================线索转换率========================================*/

    /**
     * 查询线索数
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     */
    Integer getCluesNums(@Param("beginCreateTime") String beginCreateTime,
                         @Param("endCreateTime") String endCreateTime);

    /**
     * 查询有效线索数
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     */
    Integer getEffectiveCluesNums(@Param("beginCreateTime") String beginCreateTime,
                                  @Param("endCreateTime") String endCreateTime);

    /**
     * 查询商机数
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     */
    Integer getBusinessNums(@Param("beginCreateTime") String beginCreateTime,
                            @Param("endCreateTime") String endCreateTime);

    /**
     * 查询合同数
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     */
    Integer getContractNums(@Param("beginCreateTime") String beginCreateTime,
                            @Param("endCreateTime") String endCreateTime);

    /**
     * 首页--商机龙虎榜
     */
    List<Map<String, Object>> businessChangeStatistics(@Param("beginCreateTime") String beginCreateTime,
                                                        @Param("endCreateTime") String endCreateTime);
    /**
     * 首页--线索龙虎榜
     */
    List<Map<String, Object>> salesStatistic(@Param("beginCreateTime") String beginCreateTime,
                                             @Param("endCreateTime") String endCreateTime);

    /*=========================================线索转换率========================================*/


}
